<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>p2_外间距测试</title>
    <style>
<!--去掉boby自带的8px外间距-->
        baby{
            margin: 0;
        }
        * {
            margin: 0;
            padding: 0;
        }
        .fu {
            background-color: yellow;
            overflow: hidden;/*BFC结界*/
        }
        .fu>div{
            width: 100px;
            height: 100px;
            background-color: blue;
            border: 5px solid red;
            color: #fff;
            font-size: 25px;
            font-weight: bold;
        }
        /*父子贴边:首个子元素的上外间距与最后一个元素的下外间距会超出父元素的范围
        解决方案:给父元素设置BFC结界保护*/
        .z1 {
            margin-bottom: 30px;
        }
        /*相邻兄弟在垂直方向上的间距取最大值显示，不会叠加*/
        .z2 {
            margin-top: 50px;
        }
        .z4 {
            margin-bottom: 50px;
        }
        .z3 {
            margin: 10px;/*四个方向都是10*/
            margin: 10px 20px;/*上下10 左右20*/
            margin: 10px 20px 30px;/*上10 左右20 下30*/
            margin: 10px 20px 30px 40px;/*上10 右20 下30 左40 顺时针赋值*/
            margin: 0 auto/*实现块级元素自身的水平居中，auto会自动将左右外间距计算成等值*/;
        }
        span{
            border: 2px solid red;
        }
        .s2{
            /*行内元素垂直方向上的外间距不生效*/
            margin: 30px;
        }
    </style>
</head>
<body>
<span>spa1</span><span class="s2">span2</span><span>span3</span>
<!-- .fu>.z*4 Tab补全-->
<div class="fu">
    <div class="z1">子元素1</div>
    <div class="z2">子元素2</div>
    <div class="z3">子元素3</div>
    <div class="z4">子元素4</div>
</div>
</body>
</html>